home *** CD-ROM | disk | FTP | other *** search
- # Source Generated with Decompyle++
- # File: in.pyo (Python 2.5)
-
- import Image
- import ImageFile
- import string
- import struct
- HEADERSIZE = 8
-
- def nextheader(fobj):
- return struct.unpack('>4sI', fobj.read(HEADERSIZE))
-
-
- def read_32t(fobj, .1, .2):
- (start, length) = .1
- (width, height) = .2
- fobj.seek(start)
- sig = fobj.read(4)
- if sig != '\x00\x00\x00\x00':
- raise SyntaxError, 'Unknown signature, expecting 0x00000000'
-
- return read_32(fobj, (start + 4, length - 4), (width, height))
-
-
- def read_32(fobj, .1, size):
- (start, length) = .1
- fobj.seek(start)
- sizesq = size[0] * size[1]
- if length == sizesq * 3:
- indata = fobj.read(length)
- im = Image.frombuffer('RGB', size, indata, 'raw', 'RGB', 0, 1)
- else:
- im = Image.new('RGB', size, None)
- for band_ix in range(3):
- data = []
- bytesleft = sizesq
- while bytesleft > 0:
- byte = fobj.read(1)
- if not byte:
- break
-
- byte = ord(byte)
- if byte & 128:
- blocksize = byte - 125
- byte = fobj.read(1)
- for i in range(blocksize):
- data.append(byte)
-
- else:
- blocksize = byte + 1
- data.append(fobj.read(blocksize))
- bytesleft = bytesleft - blocksize
- if bytesleft <= 0:
- break
- continue
- if bytesleft != 0:
- raise SyntaxError('Error reading %r channel [%r]' % (channel, bytesleft))
-
- band = Image.frombuffer('L', size, string.join(data, ''), 'raw', 'L', 0, 1)
- im.im.putband(band.im, band_ix)
-
- return {
- 'RGB': im }
-
-
- def read_mk(fobj, .1, size):
- (start, length) = .1
- fobj.seek(start)
- band = Image.frombuffer('L', size, fobj.read(size[0] * size[1]), 'raw', 'L', 0, 1)
- return {
- 'A': band }
-
-
- class IcnsFile:
- SIZES = {
- (128, 128): [
- ('it32', read_32t),
- ('t8mk', read_mk)],
- (48, 48): [
- ('ih32', read_32),
- ('h8mk', read_mk)],
- (32, 32): [
- ('il32', read_32),
- ('l8mk', read_mk)],
- (16, 16): [
- ('is32', read_32),
- ('s8mk', read_mk)] }
-
- def __init__(self, fobj):
- self.dct = dct = { }
- self.fobj = fobj
- (sig, filesize) = nextheader(fobj)
- if sig != 'icns':
- raise SyntaxError, 'not an icns file'
-
- i = HEADERSIZE
- while i < filesize:
- (sig, blocksize) = nextheader(fobj)
- i = i + HEADERSIZE
- blocksize = blocksize - HEADERSIZE
- dct[sig] = (i, blocksize)
- fobj.seek(blocksize, 1)
- i = i + blocksize
-
-
- def itersizes(self):
- sizes = []
- for size, fmts in self.SIZES.items():
- for fmt, reader in fmts:
- if self.dct.has_key(fmt):
- sizes.append(size)
- break
- continue
-
-
- return sizes
-
-
- def bestsize(self):
- sizes = self.itersizes()
- if not sizes:
- raise SyntaxError, 'No 32bit icon resources found'
-
- return max(sizes)
-
-
- def dataforsize(self, size):
- dct = { }
- for code, reader in self.SIZES[size]:
- desc = self.dct.get(code)
- if desc is not None:
- dct.update(reader(self.fobj, desc, size))
- continue
-
- return dct
-
-
- def getimage(self, size = None):
- if size is None:
- size = self.bestsize()
-
- channels = self.dataforsize(size)
- im = channels.get('RGB').copy()
-
- try:
- im.putalpha(channels['A'])
- except KeyError:
- pass
-
- return im
-
-
-
- class IcnsImageFile(ImageFile.ImageFile):
- format = 'ICNS'
- format_description = 'Mac OS icns resource'
-
- def _open(self):
- self.icns = IcnsFile(self.fp)
- self.mode = 'RGBA'
- self.size = self.icns.bestsize()
- self.info['sizes'] = self.icns.itersizes()
- self.tile = ('',)
-
-
- def load(self):
- Image.Image.load(self)
- if not self.tile:
- return None
-
- self.load_prepare()
- im = self.icns.getimage(self.size)
- self.im = im.im
- self.mode = im.mode
- self.size = im.size
- self.fp = None
- self.icns = None
- self.tile = ()
- self.load_end()
-
-
- Image.register_open('ICNS', IcnsImageFile, (lambda x: x[:4] == 'icns'))
- Image.register_extension('ICNS', '.icns')
- if __name__ == '__main__':
- import os
- import sys
- im = Image.open(open(sys.argv[1], 'rb'))
- im.save('out.png')
- os.startfile('out.png')
-
-